package com.huike.web.controller.review;


import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.huike.common.core.controller.BaseController;
import com.huike.common.core.domain.AjaxResult;
import com.huike.common.core.page.TableDataInfo;
import com.huike.review.pojo.Review;
import com.huike.review.service.ReviewService;
import org.apache.ibatis.annotations.Param;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.Date;
import java.util.List;

/**
 * 该Controller主要是为了复习三层架构以及Mybatis使用的，该部分接口已经放开权限，可以直接访问
 * 同学们在此处编写接口通过浏览器访问看是否能完成最简单的增删改查
 */
@RestController
@RequestMapping("/review")
public class MybatisReviewController extends BaseController {

    @Autowired
    private ReviewService reviewService;

    /**
     * =========================================================新增数据============================================
     */
    /*@GetMapping("saveData/{name}/{age}/{sex}")
    public AjaxResult saveData(@PathVariable String name,
                               @PathVariable Integer age,
                               @PathVariable String sex) {
        reviewService.savaData(name, age, sex);
        return AjaxResult.success("成功插入:一条数据");
    }*/

    @PostMapping("/saveData")
    public AjaxResult savaData(@RequestBody Review review) {
        reviewService.savaData(review);
        return AjaxResult.success("成功插入一条数据");
    }

    /**=========================================================删除数据=============================================*/
    @DeleteMapping("/remove/{id}")
    public AjaxResult remove(@PathVariable Integer id){
        reviewService.removeById(id);
        return  AjaxResult.success("成功删除一条数据");
    }

    /**=========================================================修改数据=============================================*/

    @PostMapping("/update")
    public AjaxResult update(@RequestBody Review review) {
        reviewService.update(review);
        return AjaxResult.success("修改成功");
    }

    /**=========================================================查询数据=============================================*/
    //根据id查询
    @GetMapping("/getById")
    public AjaxResult getById(@RequestParam Integer id) {
        Review review = reviewService.getById(id);
        return AjaxResult.success("查询成功", review);
    }

    //总查询
    /*@GetMapping("/getDataByPage")
    public TableDataInfo page() {
        List<Review> list = reviewService.list();
        return getDataTablePage(list);
    }*/

    //分页查询
    @GetMapping("/getDataByPage")
    public AjaxResult getDataByPage(@RequestParam Integer pageNum,
                                    @RequestParam Integer pageSize) {
        return AjaxResult.success(reviewService.getByPage(pageNum, pageSize));
    }
}